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(54) Fair share scheduling of multiple service classes with prioritized shaping 



(57) An apparatus for scheduling multi-service cate- 
gory ATM cell traffic through contention points in the 
ATM network is provided. The service categories have 
predefined delivery priorities according to quality of 
service guarantees. To satisfy these priorities while 
maintaining fair treatment to low priority connections, 
aging markers are incrementally assigned to queued 
cells and these markers in combination with priority 
data are used to determine which connection is serv- 
iced next. A method of scheduling traffic through the 
network is also disclosed. 
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Description 

Field of the Invention 

[0001] This invention relates to systems and methods 
for fairly arbitrating between multiple scheduled events 
and more particularly to systems and methods for the 
fair-share scheduling of multiple service categories at 
queuing or congestion points in an ATM network. 

Background of the Invention 

[0002] Asynchronous transfer mode (ATM) is gaining 
rapid recognition as the technology of choice for the 
transmission of broadband information. The fixed length 
cell size employed in ATM technology supports the 
delivery of a wide range of multimedia information 
including speech, video and data. In order to service 
this wide variety of information the ATM Traffic Manage- 
ment Forum has specified that ATM traffic be divided 
into five service categories. Two of these service cate- 
gories are for real-time transmission, namely constant 
bit rate (CBR) and real-time variable bit rate (rtVBR). 
There are, as well, three non-real-time categories, 
namely non-real-time variable bit rate (nrt-VBR); 
unspecified bit rate (UBR) and available bit rate (ABR). 
[0003] As the various service categories are designed 
to carry different types of information, different Quality 
of Service (QoS) parameters apply. The ATM Traffic 
Management Forum has listed six Quality of Service 
parameters namely: peak-to-peak Cell Delay Variation 
(peak-to-peak CDV); maximum Cell Transfer Delay 
(Max CTD); Cell Loss Ratio (CLR); Cell Error Ratio 
(CER); Severely Errored Cell Block Ratio (SECBR) and 
Cell Misinsertion Ratio (CMR). Of these six, two are of 
greatest concern when scheduling. These are the max- 
imum Cell Transfer Delay (Max CTD) and Cell Delay 
Variation (CDV). Traffic of different service classes, and 
even traffic of the same service class may have different 
delay requirements. Fair scheduling between connec- 
tions of the various ATM service categories onto a sin- 
gle resource while meeting the multiple Quality of 
Service delay guarantees is difficult to achieve. 
[0004] One prior art method for scheduling such traf- 
fic, known as shaping, involves calculating a theoretical 
emission time (TET) for each active connection and 
attempting to service each connection as close to that 
theoretical emission time as possible. Unfortunately, 
most connections cannot be serviced exactly at their 
TET due to finite output time requirements for the 
shared resource, as well as scheduling collisions where 
multiple connections are scheduled to output at the 
same time. Though the finite output times cannot be 
avoided, the effects of scheduling collisions can and 
should be reduced through prioritization. Without priori- 
tization, a connection with loose delay requirements 
may actually get serviced prior to a connection with tight 
delay requirements scheduled at the same TET 



[0005] One proposed solution to this problem is to use 
two or more shaping devices (or shapers) to schedule 
the connections where connections with similar Quality 
of Service delay requirements are scheduled in the 

s same shaper. Exhaustive servicing is commonly used to 
determine which shaper gets to send a cell at any given 
time. Prioritized shaping is discussed in US application 
S.N. which is based on provisional application 
60/020,642 filed June 27, 1996. The contents of the 

io aforementioned application are incorporated herein by 
reference. When more than one calendar (as defined in 
the aforementioned application) contains a connection 
ready to send a cell, only the highest priority calendar 
gets to transmit. AH lower priority calendars have to wait 

15 until all calendars with higher priority have nothing 
ready to send. This calendar prioritization can be based 
upon the CDV and possibly max CTD requirements of 
the traffic scheduled in each calendar. There are, how- 
ever, certain limitations which can be identified in con- 

20 nection with the aforementioned multiple shaper or 
calendar solution. For example, there is no quantitative 
link between the CDV and max CTD requirements 
between each shaper's traffic and the prioritization of 
that shaper respective of all other shapers. When a high 

25 priority shaper schedules several connections over a 
relatively short transient period, lower priority shapers 
have to wait until this transient finishes before they can 
resume sending cells from their connections. During 
these transients, low priority connections may violate 

30 their delay requirements while those scheduled on high 
priority shapers may actually beat their delay require- 
ments. Thus, high priority connections may actually bet- 
ter their QoS at the expense of lower priority 
connections. To properly support QoS delay require- 

35 ments, shaper priorities must be dynamically assigned 
based upon the amount of time that their connections 
have been delayed from ideal theoretical emission 
times. 

[0006] Further, heretofore traffic is either shaped or 

40 placed in work-conserving, weighted-fair-queues. 
Shaping works well for real-time traffic where rates are 
explicitly guaranteed and weighted-fair<|ueuing works 
well for non-real-time traffic that does not need to be pri- 
oritized or rate limited. However, most non -real -time 

45 traffic has an associated minimum rate that must be 
guaranteed and a maximum rate that cannot be 
exceeded. It is also often desirable to provide work con- 
servation between these two limits to ensure full 
resource usage as precise instantaneous bandwidth 

so availability is rarely known for non-real-time traffic. An 
example would be non -real -time variable bit rate where 
the minimum guaranteed scheduled rate is sustainable 
cell rate (SCR) though output rate will be lower when an 
upstream source sends below SCR. The maximum rate 

55 is peak cell rate (PCR) with an associated burst toler- 
ance (BT) that must be respected. In this case it is not 
desirable to simply shape up to PCR as this may 
infringe upon rate guarantees of the available bit rate 
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(ABR) and possibly unspecified bit rate (UBR) connec- 
tions. On the other hand, it is also not desirable to sim- 
ply shape to SCR as this does not allow the non-real- 
time variable bit rate connection to make use of any 
additional unused bandwidth. This minimum rate guar- 
antee with work conservation up to a maximum rate 
cannot be provided for by shaping or weighted-fair- 
queuing alone. 

[0007] Furthermore, scheduling using a single device, 
namely a shaper or a weighted-fair-queue, does not 
provide proper support for rate-based backpressure 
where all non-real-time connections are throttled back 
to minimum required rates. Weighted-fair-queuing by 
itself is not able to throttle back all connections due to its 
work-conserving nature, while shaping is far too slow to 
respond. For a shaper to throttle back the rates of all 
connections scheduled, these connections would either 
have to be descheduled and rescheduled with a longer 
period or the shaper would have to wait for each con- 
nection to be serviced before rescheduling it with a 
longer period. At the conclusion of the backpressure, 
the same procedure would have to be followed for 
increasing the rates of the connections. As thousands of 
connections may be scheduled these procedures would 
take a very long time to complete. The net effect is an 
increased delayjn the control loop which is therefore 
harder to stabilize. 

Summary of the Invention 

[0008] It is therefore an object of the present invention 
to provide fair share scheduling of multiple scheduled 
events of different service classes with exhaustive by 
age priority servicing. 

[0009] It is a further object of the present invention to 
provide fair share scheduling with work conservation 
and prioritized minimum rate. 

[0010] It is also an object of the present invention to 
provide fair share scheduling and peak rate limiting. 
[001 1] Therefore in accordance with a first aspect of 
the present invention there is provided an apparatus for 
arbitrating service between contending multiple sched- 
uled events each having a predefined service delivery 
priority and a preset delay factor, where the delay factor 
corresponds directly to the CDV, and also relates to max 
CTD. Note that max CTD is also a function of the vari- 
ance in the input stream since shapers use delay to 
smooth out this variance. The apparatus comprises 
queuing means to place sequential events in per 
sequence queues; scheduling means to determine 
sequence service times and to group sequences of sim- 
ilar service quality; aging means to monitor sequence 
groups and to record aging components for each group, 
each aging component representing the largest delay 
suffered by the sequences in the group; and servicing 
means to selectively service a sequence having the 
highest aggregate of service priority and aging compo- 
nent. 



[0012] In accordance with a second aspect of the 
present invention there is provided an apparatus for 
arbitrating between service connections at a contention 
point in an ATM network, the service connections 

s including multiple service categories each with prede- 
fined Quality of Service guarantees. The apparatus 
comprises queuing means for arranging sequential 
items in per sequence queues; scheduling means to 
determine sequence service times and to group 

10 sequences of similar service quality; aging means to 
monitor sequence groups and to introduce aging mark- 
ers to sequence groups that have been waiting the long- 
est to send; and servicing means to selectively service 
a sequence having the highest aggregate of service pri- 

is ority and aging markers. 

[001 3] In a preferred embodiment of this aspect of the 
invention the scheduling means includes parallel shaper 
and weighted-fair-queuing means for specific service 
categories whereby the shaper provides a minimum 

20 rate guarantee and the weighted-fair-queuing means 
provides optimum bandwidth usage. 
[0014] In accordance with a further embodiment of 
this aspect of the invention shaping means may also be 
provided to limit peak rate offered to sequences by the 

25 weighted-fair-queuing means. 

[0015] In accordance with a third aspect of the present 
invention there is provided a method of fairly scheduling 
sequential events of various service categories at a 
queuing point in an ATM network in order to satisfy 

30 Quality of Service guarantees. The method comprises 
the steps of placing sequential events into per- 
sequence queues; prioritizing the per-sequence queues 
in sequence groups of similar service quality; recording 
a timing marker for each sequence group, the timing 

35 marker representing the largest delay suffered by the 
sequences in the group; accumulating priority and timer 
marker data respecting each group; and selectively 
servicing the sequence having the highest aggregate of 
service priority and timing markers. 

40 

Brief Description of the Drawings 

[0016] The invention will now be described in greater 
detail with reference to the attached drawings wherein: 

45 

Figure 1 is a sample multiple calendar scheduler 
according to the prior art; 

Figure 2 illustrates exhaustive by age priority serv- 
icing according to the present invention; and 
so Figure 3 shows work conservation with prioritized 
minimum rate;and rate limiting. 

; e 

Detailed Description of the Invention 

55 [0017] Figure ,1 demonstrates an implementation of a 
prior art queue servicing solution using multiple shaping 
calendars 12 which constitutes a particular form of a 
traffic shaper. The calendars 12 are prioritized. When 
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more than one calendar 12 contains a connection ready 
to send a cell only the highest priority calendar gets to 
transmit. All lower priority calendars have to wait until all 
calendars with higher priority have nothing ready to 
send. In Figure 1 a low priority weighted-fair-queuing 5 
( WFQ) scheduler 1 4 which could be in the torm of a cal- 
endar, a tag comparator or other WFQ method has 
been added to provide work-conserving support for low 
priority connections such as UBR, Calendars could be 
divided based upon the traffic type (real-time or non- io 
real-time) service category (CBR, rtVBR, nrt-VBR, 
ABR, UBR) delay requirements (such as CDV and max 
CTD) requirements or a combination of these such as 
delay requirements for real-time traffic and service cat- 
egory for non-real-time traffic. Since Quality of Service 75 
(QoS) can be related to network node CDV and max 
CTD requirements, dividing calendars within the node 
based upon these requirements prioritize traffic based 
upon QoS. 

[0018] Generally speaking, traffic with tight CDV 20 
requirements should be transmitted as close to the the- 
oretical emission time as possible. However, if several 
connections with tight CDV are scheduled in proximity to 
each other and receive exhaustive priority, it is possible 
that a connection with a larger CDV scheduled near the 25 
beginning of the high priority group may get delayed 
beyond its CDV requirement. 

[0019] To avoid this, in accordance with the present 
invention, an aging factor is added which allows low pri- 
ority large CDV connections to boost their priority as 30 
they get delayed close to the CDV limit for the node. An 
exhaustive by age priority servicing method is used to 
service between the multiple shapers. This will also limit 
max CTD for connections on lower priority shapers, 
though quantizing max CTD for shaped traffic requires 35 
knowledge of the traffic pattern at the input of the 
shaper. 

[0020] In the following description reference is made 
to calendars. As used herein a calendar is a traffic shap- 
ing entity which, in effect, defines a succession of time 40 
intervals, in each of which are identified queues to be 
serviced during that interval. 

[0021] Figure 2 demonstrates one implementation of 
exhaustive by age priority servicing. Connections are 
shaped using multiple calendars 20, where each calen- 45 
dar has a programmable 1 -point CDV associated with it. 
The 1 -point CDV is described in ATM Forum's Traffic 
Management Specification Version 4.0. In the multiple 
calendar architecture illustrated in Figure 2 the position 
of each queue within the calendar is determined by the so 
Generic Cell Rate Algorithm (GCRA) also defined in the 
aforementioned ATM Forum's Traffic Management 
Specification. In this example a WFQ calendar 22 is 
also available to provide work conservation for low prior- 
ity connections, though no aging is associated with it. 55 
One or more age thresholds are provided for each 
shaping calendar to support aging as the calendar gets 
behind in service relative to TET. One threshold could 
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be set at or near the desired CDV limit for the calendar, 
while any others could be set above and/or below the 
CDV to provide additional resolution. An aging bitmap 
24 is associated with the group of calendars, with one 
bit 26 per threshold per calendar, plus one additional bit 
per calendar to indicate that the calendar has a connec- 
tion ready to be serviced. 

[0022] When a calendar reaches the time where a 
connection is scheduled to transmit, the first bit in the 
age bitmap is set to indicate that a connection is ready. 
If the connection cannot be serviced due to other con- 
nections waiting in higher priority calendars, additional 
bits will be set in the bitmap as each aging threshold is 
crossed. When determining which connection should 
be serviced next, the aging bitmap is read and the earli- 
est scheduled connection on the highest priority calen- 
dar with the highest count of age bits set is serviced. 
This assumes age takes precedence to priority. At this 
point the age bitmap is updated if necessary to reflect 
the servicing. 

[0023] This example demonstrates the use of a two 
pointer shaper for determining how far behind each cal- 
endar is. The Real Time Pointer (RTP) points to the 
ideal service point, while the Virtual Time Pointer (VTP) 
points to the actual service point. The RTP constantly 
increments at fixed intervals, whereas the VTP points to 
a particular time slot in the calendar which defines the 
next connection, i.e. cell to be serviced. The VTP can 
only be incremented if a connection is serviced from the 
calendar or if the RTP increments and there are no con- 
nections ready to be serviced. The distance between 
the two pointers determines currently how delayed the 
oldest connection is from its TET and can be calculated 
every time the RTP increments. 
[0024] It would be possible to use this aging mecha- 
nism for other implementations of shapers as well. For 
example, if connections are removed from the calendar 
as soon as their TET is reached and placed in a queue 
associated with the calendar until they can be serviced, 
their TET values can be used to set the aging bits. In 
this case, the connection at the head of the queue is the 
oldest, and its TET value can be compared to the cur- 
rent time and aging thresholds in order to set the aging 
bits. Furthermore, the shaper does not have to take the 
form of a calendar. 

[0025] Although this example demonstrates the use of 
exhaustive by age priority servicing as it relates to shap- 
ing ATM connections, the same principles can be used 
for any application where multiple scheduled events 
have to be arbitrated between based upon priority and 
delay variances. 

[0026] This method provides a much better means of 
ensuring that CDV requirements are not violated during 
scheduling collisions, as compared to simple exhaustive 
servicing. Large scheduling collisions in high priority 
calendars will not be able to starve lower priority con- 
nections. CDV limits for all priorities can be guaranteed 
assuming the scheduler is not overbooked, unlike 
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exhaustive servicing that can only guarantee CDV limits 
to higher priority connections when the scheduler is 
more than minimally booked. 

[0027] Implementing additional threshold levels below 
network node CDV requirements provides a better 
means to distribute the effects of a minor scheduling 
collision among all priorities, as opposed to only involv- 
ing low priority traffic until CDV limits have been 
reached. Implementing additional threshold levels 
above CDV can minimize the relative size of CDV viola- 
tions by distributing violations across all priorities during 
excessive scheduling collisions, instead of violating only 
low priority connections. Of course for some traffic 
classes it may be more desirable to avoid CDV viola- 
tions for higher priority traffic at the expense of large 
CDV violations for lower priority traffic during large colli- 
sions, instead of spreading the violations equally. In this 
case aging threshold levels above CDV may not be 
acceptable. Thresholds can also be set to differentiate 
between calendars shaping non-real-time traffic, 
although these thresholds should be large enough to 
prevent non real-time traffic from ever obtaining higher 
priority than real-time traffic. 

[0028] By scheduling a connection with both a shaper 
and a WFQ at the same time, it is possible to provide a 
minimum rate guarantee with work conservation provid- 
ing any additionally available bandwidth. The shaper will 
shape to the minimum rate, while the WFQ provides 
everything above. This supports rate-based backpres- 
sure, where the non-real-time traffic can be throttled 
back to minimum rates simply by halting service of the 
WFQ. 

[0029] Figure 3 demonstrates a sample configuration 
for work conservation with prioritized minimum rate and 
peak rate limiting. In this example the nrt-VBR is shaped 
at SCR in a separate calendar 30 from the calendar 32 
for ABR and UBR. This gives the nrt-VBR priority during 
transients where insufficient bandwidth is available to 
provide minimum rates to all three non-real time 
classes. Aging can be utilized to prevent the ABR and 
UBR from being starved completely during the tran- 
sients. ABR and UBR are shaped to their MCR values. 
In Figure 3 a separate shaper is provided for peak rate 
limiting as will be discussed later. WFQ weights are set 
to provide a fair-share of the remaining bandwidth to all 
of the non-real-time connections. This example 
assumes that fair-share is relative to the difference 
between the peak rate and the minimum rate. If the fair- 
share calculations for ABR explicit rate (ER) calcula- 
tions differs from this, the WFQ weights might have to 
be modified accordingly. 

[0030] When scheduling on two calendars 30, 36 
simultaneously, care must be taken to ensure that cell 
sequence integrity is maintained, and that empty cells 
are not inadvertently sent out due to connections with 
only one cell queued being scheduled on two calendars. 
Cell sequence integrity can easily be preserved by 
scheduling connections rather than cells. This ensures 



that the cell at the head of the queue is first to go out 
regardless as to which of the two calendars is first to 
service the connection. There is always a possibility that 
a connection with only one cell queued can be sched- 

5 uled in two calendars, though the probability of this can 
be substantially reduced. When a cell arrives to an 
empty queue, the connection need only be scheduled in 
the shaper. If the shaper sends this cell out before the 
next cell arrives, then the connection again only needs 

10 to be scheduled in the shaper since the cells are arriv- 
ing at or below the minimum rate. However, if another 
cell arrives prior to the first being sent, the connection 
should be scheduled into the WFQ as well. After this, 
the connection will be rescheduled every time it is serv- 

75 iced by either calendar until the connection's queue 
empties. When a queue that is scheduled in two calen- 
dars empties, the connection will have to be removed 
from the calendar in which it is still scheduled. This 
descheduling will have to occur prior to the next output 

20 cell time to ensure that the empty queue is not acciden- 
tally serviced. 

[0031] As WFQ is work conserving, there may be a 
need to limit peak rates. Peak rate limiting can be 
achieved by rescheduling, with a shaper 34, connec- 
ts tions that have been serviced too early by the WFQ 36. 
To determine that a connection has been serviced too 
early by the WFQ 36, a theoretical emission time can be 
calculated based upon the peak rate at each emission 
time, and compared to the actual emission time (AET). 
30 If the AET is less than the TET, the connection has been 
serviced too early and will have to be scheduled in the 
shaper 34 at an emission time of TET offset by the 
period corresponding to the peak rate. After the connec- 
tion has been serviced by the shaper, the average rate 
35 over two cell times is no longer in violation of the peak 
rate, so the connection can again be scheduled in the 
WFQ 36, assuming more cells are available. This pro- 
vides for a maximum CDV of one peak rate cell time in 
addition to the maximum CDV provided by the shaper, 
40 and ensures that the peak rate is never violated over a 
two cell emission interval. 

[0032] For the sample configuration of Figure 3, 
shaper n (34) provides for peak rate limiting the output 
of the WFQ 36. Depending on design limitations, it may 

45 be possible to use one of the minimum rate shapers to 
also provide for peak rate limiting if it is possible to 
schedule the same connection twice within the same 
calendar. If not, the separate peak rate shaper will only 
get utilized when the WFQ is sufficiently underbooked. 

so [0033] In this sample configuration, the peak rate for 
nrt-VBR is PCR-SCR7 r but this must also respect the 
burst tolerance. To ensure nrt-VBR burst tolerance (BT) 
is not exceeded, credits (x) can be accumulated when- 
ever the connection sends at less than SCR, up to a 

55 limit of BT. Only if there are enough credits accumulated 
for the transmission of at least one cell at PCR will the 
VBR connection be eligible for scheduling in the WFQ 
calendar. Credits are subtracted every time the connec- 
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tion is serviced by the WFQ calendar. As soon as there 
are insufficient credits, the connection wilt no longer be 
eligible for WFQ scheduling until its queue runs empty, 
as a non-empty queue indicates that the connection is 
still being shaped to SCR. 5 
[0034] By rescheduling connections that have 
reached their peak rates in a shaper, connections can 
be capped at their peak rates independently of their 
weights in the WFQ. This independence from WFQ 
weights allows connections that have small peak rates 10 
relative to their WFQ weights to be capped without inter- 
fering with the work-conserving service of those con- 
nections with relatively high peak rates. 
[0035] Although specific embodiments of the invention 
have been described and illustrated it will be apparent is 
to one skilled in the art that various modifications can be 
made to these embodiments without departing from the 
basic inventive concepts. It is to be understood that 
such modifications, to the extent possible, fall within the 
scope of the invention as defined by the appended 20 
claims. 

Claims 

1 . An apparatus for arbitrating service between con- 25 
tending multiple scheduled events having a prede- 
fined service delivery priority and a preset delay 
factor, said apparatus comprising: 

queuing means to place sequential items in per 30 
sequence queues; 

scheduling means to determine sequence 
service times and to group sequences of simi- 
lar service quality; 

aging means to monitor sequence groups and 35 
to record aging components for each group, 
each of said aging components representing 
the largest delay suffered by sequences in said 
group; and 

servicing means to selectively service a 40 
sequence having the highest aggregate of 
service priority and aging component 

2. An apparatus as defined in claim 1 wherein said 
delay factor corresponds directly to Cell Delay Vari- 45 
ation (CDV). 

3. An apparatus as defined in claim 1 wherein said 
delay factor relates to maximum Cell Transfer Delay 
(maxCTD). 50 

4. An apparatus for arbitrating between service con- 
nections at a contention point in an ATM network, 
said service connections including multiple service 
categories each with predefined quality of service 55 
guarantees, said apparatus comprising: 

queuing means for arranging sequential items 



in per sequence queues; 
scheduling means to determine sequence 
service times and to group sequences of simi- 
lar service quality; 

aging means to monitor sequence groups and 
to introduce aging markers to sequence groups 
that have been waiting beyond set thresholds 
to send; and 

servicing means to selectively service a 
sequence having the highest aggregate of 
service priorities and aging markers. 

5. An apparatus as defined in claim 1 wherein said 
scheduling means includes multiple shaping 
means. 

6. An apparatus as defined in claim 5 further including 
one or more work-conserving means. 

7. An apparatus as defined in claim 5 wherein said 
shaping means are shaping calendars. 

8. An apparatus as defined in claim 6 wherein said 
work-conserving means is a weighted-fair-queuing 
scheduler. 

9. An apparatus as defined in claim 4 wherein said 
aging means introduces multiple aging markers to 
each sequence group, an aging marker being 
added each time a time interval is passed without 
said connection being serviced. 

10. An apparatus as defined in claim 4 wherein said 
scheduling means includes parallel shaper and 
weighted fair queuing means for specific service 
categories whereby said shaper provides a mini- 
mum rate guarantee and said weighted fair queuing 
means provides optimum bandwidth usage. 

11. An apparatus as defined in claim 10 wherein said 
parallel shaping means and said weighted fair 
queuing means supports rate controlled backpres- 
sure for specific service categories. 

12. An apparatus as defined in claim 10 wherein said 
specific service categories may be scheduled in 
either a shaper or a weighted fair queuing means in 
order to limit the peak cell delivery rate. 

13. A method of fairly scheduling sequential events of 
various service categories at a queuing point in an 
ATM network in order to satisfy Quality of Service 
guarantees, the method comprising: 

placing sequential events into per sequence 
queues; 

prioritizing said per sequence queues in 
sequence groups of similar service quality; 
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recording a timing marker for each sequence 
group, said timing marker representing the 
largest delay suffered by said sequence queue 
in said sequence group; 

accumulating priority and timing marker data s 
respecting each group; and 
selectively servicing the sequence queue hav- 
ing the highest aggregate of priority and timing 
markers. 
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